package me.zhengjie.org.centerbase.service;

import me.zhengjie.org.centerbase.domain.CenterBase;
import me.zhengjie.org.centerbase.service.dto.CenterBaseDto;
import me.zhengjie.org.centerbase.service.dto.CenterBaseQueryCriteria;
import org.springframework.data.domain.Pageable;
import java.util.Map;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;

/**
* @author ZGZ
* @date 2020-04-15
*/
public interface CenterBaseService {

    /**
    * 查询数据分页
    * @param criteria 条件
    * @param pageable 分页参数
    * @return Map<String,Object>
    */
    Map<String,Object> queryAll(CenterBaseQueryCriteria criteria, Pageable pageable);

    /**
    * 查询所有数据不分页
    * @param criteria 条件参数
    * @return List<CenterBaseDto>
    */
    List<CenterBaseDto> queryAll(CenterBaseQueryCriteria criteria);

    /**
     * 根据ID查询
     * @param id ID
     * @return CenterBaseDto
     */
    CenterBaseDto findById(Integer id);

    /**
    * 创建
    * @param resources /
    * @return CenterBaseDto
    */
    CenterBaseDto create(CenterBase resources);

    /**
    * 编辑
    * @param resources /
    */
    void update(CenterBase resources);

    /**
    * 多选删除
    * @param ids /
    */
    void deleteAll(Integer[] ids);

    /**
    * 导出数据
    * @param all 待导出的数据
    * @param response /
    * @throws IOException /
    */
    void download(List<CenterBaseDto> all, HttpServletResponse response) throws IOException;
}